package lcof;

/**
 * @author 江岸
 * @version V1.0
 * @ClassName: FindNumberIn2DArray4
 * @description: 在一个 n * m 的二维数组中，每一行都按照从左到右递增的顺序排序，每一列都按照从上到下递增的顺序排序。请完成一个高效的函数，输入这样的一个二维数组和一个整数，判断数组中是否含有该整数。
 *
 *
 *
 * 示例:
 *
 * 现有矩阵 matrix 如下：
 *
 * [
 *   [1,   4,  7, 11, 15],
 *   [2,   5,  8, 12, 19],
 *   [3,   6,  9, 16, 22],
 *   [10, 13, 14, 17, 24],
 *   [18, 21, 23, 26, 30]
 * ]
 *
 * 给定 target = 5，返回 true。
 *
 * 给定 target = 20，返回 false。
 *
 * 来源：力扣（LeetCode）
 * 链接：https://leetcode-cn.com/problems/er-wei-shu-zu-zhong-de-cha-zhao-lcof
 * 著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。
 * @date 2021/2/2316:43
 * @since V1.0
 */
public class FindNumberIn2DArray4 {

    public boolean findNumberIn2DArray(int[][] matrix, int target) {
        //行
        int i=matrix.length-1;
        //列
        int j=0;
        while(i>=0 && j<matrix[0].length){
            if (matrix[i][j]<target){
                //如果左下角元素小于目标值，则列往右移动
                j++;
            }else if(matrix[i][j]>target){
                //如果左下角元素大于目标值，则行往上移动
                i--;
            }else{
                return true;
            }
        }
        return false;
    }
}
